Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[PR #8652/b0536ae6 backport][3.10] Do not follow symlinks for compressed file variants #8653

Conversation

patchback[bot]
Copy link
Contributor

@patchback patchback bot commented Aug 8, 2024

This is a backport of PR #8652 as merged into master (b0536ae).

None

Co-authored-by: Steve Repsher <[email protected]>
(cherry picked from commit b0536ae)
@bdraco bdraco enabled auto-merge (squash) August 8, 2024 16:19
Copy link

codecov bot commented Aug 8, 2024

Codecov Report

All modified and coverable lines are covered by tests ✅

Please upload report for BASE (3.10@6a77806). Learn more about missing BASE report.

Additional details and impacted files
@@           Coverage Diff           @@
##             3.10    #8653   +/-   ##
=======================================
  Coverage        ?   97.71%           
=======================================
  Files           ?      108           
  Lines           ?    33922           
  Branches        ?     4036           
=======================================
  Hits            ?    33146           
  Misses          ?      579           
  Partials        ?      197           
Flag Coverage Δ
CI-GHA 97.61% <100.00%> (?)
OS-Linux 97.29% <100.00%> (?)
OS-Windows 94.80% <100.00%> (?)
OS-macOS 96.96% <100.00%> (?)
Py-3.10.11 97.06% <100.00%> (?)
Py-3.10.14 97.01% <100.00%> (?)
Py-3.11.9 97.24% <100.00%> (?)
Py-3.12.4 97.34% <100.00%> (?)
Py-3.8.10 94.54% <100.00%> (?)
Py-3.8.18 96.91% <100.00%> (?)
Py-3.9.13 97.05% <100.00%> (?)
Py-3.9.19 97.01% <100.00%> (?)
Py-pypy7.3.16 96.60% <100.00%> (?)
VM-macos 96.96% <100.00%> (?)
VM-ubuntu 97.29% <100.00%> (?)
VM-windows 94.80% <100.00%> (?)

Flags with carried forward coverage won't be shown. Click here to find out more.

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@bdraco bdraco merged commit ce2e975 into 3.10 Aug 8, 2024
30 of 31 checks passed
@bdraco bdraco deleted the patchback/backports/3.10/b0536ae6babf160105d4025ea87c02b9fa5629f1/pr-8652 branch August 8, 2024 16:36
holtskinner referenced this pull request in GoogleCloudPlatform/generative-ai Sep 17, 2024
This PR contains the following updates:

| Package | Change | Age | Adoption | Passing | Confidence |
|---|---|---|---|---|---|
| [aiohttp](https://redirect.github.com/aio-libs/aiohttp) | `3.9.5` ->
`3.10.2` |
[![age](https://developer.mend.io/api/mc/badges/age/pypi/aiohttp/3.10.2?slim=true)](https://docs.renovatebot.com/merge-confidence/)
|
[![adoption](https://developer.mend.io/api/mc/badges/adoption/pypi/aiohttp/3.10.2?slim=true)](https://docs.renovatebot.com/merge-confidence/)
|
[![passing](https://developer.mend.io/api/mc/badges/compatibility/pypi/aiohttp/3.9.5/3.10.2?slim=true)](https://docs.renovatebot.com/merge-confidence/)
|
[![confidence](https://developer.mend.io/api/mc/badges/confidence/pypi/aiohttp/3.9.5/3.10.2?slim=true)](https://docs.renovatebot.com/merge-confidence/)
|

---

> [!WARNING]
> Some dependencies could not be looked up. Check the warning logs for
more information.

### GitHub Vulnerability Alerts

####
[CVE-2024-42367](https://redirect.github.com/aio-libs/aiohttp/security/advisories/GHSA-jwhx-xcg6-8xhj)

### Summary
Static routes which contain files with compressed variants (`.gz` or
`.br` extension) were vulnerable to path traversal outside the root
directory if those variants are symbolic links.

### Details
The server protects static routes from path traversal outside the root
directory when `follow_symlinks=False` (default). It does this by
resolving the requested URL to an absolute path and then checking that
path relative to the root. However, these checks are not performed when
looking for compressed variants in the `FileResponse` class, and
symbolic links are then automatically followed when performing
`Path.stat()` and `Path.open()` to send the file.

### Impact
Servers with static routes that contain compressed variants as symbolic
links, pointing outside the root directory, or that permit users to
upload or create such links, are impacted.

----

Patch:
[https://github.com/aio-libs/aiohttp/pull/8653](https://redirect.github.com/aio-libs/aiohttp/pull/8653)/files

---

### Release Notes

<details>
<summary>aio-libs/aiohttp (aiohttp)</summary>

###
[`v3.10.2`](https://redirect.github.com/aio-libs/aiohttp/blob/HEAD/CHANGES.rst#3102-2024-08-08)

[Compare
Source](https://redirect.github.com/aio-libs/aiohttp/compare/v3.10.1...v3.10.2)

\===================

## Bug fixes

- Fixed server checks for circular symbolic links to be compatible with
Python 3.13 -- by :user:`steverep`.

    *Related issues and pull requests on GitHub:*
    :issue:`8565`.

- Fixed request body not being read when ignoring an Upgrade request --
by :user:`Dreamsorcerer`.

    *Related issues and pull requests on GitHub:*
    :issue:`8597`.

- Fixed an edge case where shutdown would wait for timeout when the
handler was already completed -- by :user:`Dreamsorcerer`.

    *Related issues and pull requests on GitHub:*
    :issue:`8611`.

- Fixed connecting to `npipe://`, `tcp://`, and `unix://` urls -- by
:user:`bdraco`.

    *Related issues and pull requests on GitHub:*
    :issue:`8632`.

- Fixed WebSocket ping tasks being prematurely garbage collected -- by
:user:`bdraco`.

There was a small risk that WebSocket ping tasks would be prematurely
garbage collected because the event loop only holds a weak reference to
the task. The garbage collection risk has been fixed by holding a strong
reference to the task. Additionally, the task is now scheduled eagerly
with Python 3.12+ to increase the chance it can be completed immediately
and avoid having to hold any references to the task.

    *Related issues and pull requests on GitHub:*
    :issue:`8641`.

- Fixed incorrectly following symlinks for compressed file variants --
by :user:`steverep`.

    *Related issues and pull requests on GitHub:*
    :issue:`8652`.

## Removals and backward incompatible breaking changes

- Removed `Request.wait_for_disconnection()`, which was mistakenly added
briefly in 3.10.0 -- by :user:`Dreamsorcerer`.

    *Related issues and pull requests on GitHub:*
    :issue:`8636`.

## Contributor-facing changes

- Fixed monkey patches for `Path.stat()` and `Path.is_dir()` for Python
3.13 compatibility -- by :user:`steverep`.

    *Related issues and pull requests on GitHub:*
    :issue:`8551`.

## Miscellaneous internal changes

- Improved WebSocket performance when messages are sent or received
frequently -- by :user:`bdraco`.

The WebSocket heartbeat scheduling algorithm was improved to reduce the
`asyncio` scheduling overhead by decreasing the number of
`asyncio.TimerHandle` creations and cancellations.

    *Related issues and pull requests on GitHub:*
    :issue:`8608`.

- Minor improvements to various type annotations -- by
:user:`Dreamsorcerer`.

    *Related issues and pull requests on GitHub:*
    :issue:`8634`.

***

###
[`v3.10.1`](https://redirect.github.com/aio-libs/aiohttp/compare/v3.10.0...v3.10.1)

[Compare
Source](https://redirect.github.com/aio-libs/aiohttp/compare/v3.10.0...v3.10.1)

###
[`v3.10.0`](https://redirect.github.com/aio-libs/aiohttp/compare/v3.9.5...v3.10.0)

[Compare
Source](https://redirect.github.com/aio-libs/aiohttp/compare/v3.9.5...v3.10.0)

</details>

---

### Configuration

📅 **Schedule**: Branch creation - At any time (no schedule defined),
Automerge - At any time (no schedule defined).

🚦 **Automerge**: Enabled.

♻ **Rebasing**: Whenever PR is behind base branch, or you tick the
rebase/retry checkbox.

🔕 **Ignore**: Close this PR and you won't be reminded about this update
again.

---

- [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check
this box

---

This PR was generated by [Mend Renovate](https://mend.io/renovate/).
View the [repository job
log](https://developer.mend.io/github/GoogleCloudPlatform/generative-ai).

<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzOC44MC4wIiwidXBkYXRlZEluVmVyIjoiMzguODAuMCIsInRhcmdldEJyYW5jaCI6Im1haW4iLCJsYWJlbHMiOltdfQ==-->
nhootan referenced this pull request in nhootan/generative-ai Sep 18, 2024
…loudPlatform#1102)

This PR contains the following updates:

| Package | Change | Age | Adoption | Passing | Confidence |
|---|---|---|---|---|---|
| [aiohttp](https://redirect.github.com/aio-libs/aiohttp) | `3.9.5` ->
`3.10.2` |
[![age](https://developer.mend.io/api/mc/badges/age/pypi/aiohttp/3.10.2?slim=true)](https://docs.renovatebot.com/merge-confidence/)
|
[![adoption](https://developer.mend.io/api/mc/badges/adoption/pypi/aiohttp/3.10.2?slim=true)](https://docs.renovatebot.com/merge-confidence/)
|
[![passing](https://developer.mend.io/api/mc/badges/compatibility/pypi/aiohttp/3.9.5/3.10.2?slim=true)](https://docs.renovatebot.com/merge-confidence/)
|
[![confidence](https://developer.mend.io/api/mc/badges/confidence/pypi/aiohttp/3.9.5/3.10.2?slim=true)](https://docs.renovatebot.com/merge-confidence/)
|

---

> [!WARNING]
> Some dependencies could not be looked up. Check the warning logs for
more information.

### GitHub Vulnerability Alerts

####
[CVE-2024-42367](https://redirect.github.com/aio-libs/aiohttp/security/advisories/GHSA-jwhx-xcg6-8xhj)

### Summary
Static routes which contain files with compressed variants (`.gz` or
`.br` extension) were vulnerable to path traversal outside the root
directory if those variants are symbolic links.

### Details
The server protects static routes from path traversal outside the root
directory when `follow_symlinks=False` (default). It does this by
resolving the requested URL to an absolute path and then checking that
path relative to the root. However, these checks are not performed when
looking for compressed variants in the `FileResponse` class, and
symbolic links are then automatically followed when performing
`Path.stat()` and `Path.open()` to send the file.

### Impact
Servers with static routes that contain compressed variants as symbolic
links, pointing outside the root directory, or that permit users to
upload or create such links, are impacted.

----

Patch:
[https://github.com/aio-libs/aiohttp/pull/8653](https://redirect.github.com/aio-libs/aiohttp/pull/8653)/files

---

### Release Notes

<details>
<summary>aio-libs/aiohttp (aiohttp)</summary>

###
[`v3.10.2`](https://redirect.github.com/aio-libs/aiohttp/blob/HEAD/CHANGES.rst#3102-2024-08-08)

[Compare
Source](https://redirect.github.com/aio-libs/aiohttp/compare/v3.10.1...v3.10.2)

\===================

## Bug fixes

- Fixed server checks for circular symbolic links to be compatible with
Python 3.13 -- by :user:`steverep`.

    *Related issues and pull requests on GitHub:*
    :issue:`8565`.

- Fixed request body not being read when ignoring an Upgrade request --
by :user:`Dreamsorcerer`.

    *Related issues and pull requests on GitHub:*
    :issue:`8597`.

- Fixed an edge case where shutdown would wait for timeout when the
handler was already completed -- by :user:`Dreamsorcerer`.

    *Related issues and pull requests on GitHub:*
    :issue:`8611`.

- Fixed connecting to `npipe://`, `tcp://`, and `unix://` urls -- by
:user:`bdraco`.

    *Related issues and pull requests on GitHub:*
    :issue:`8632`.

- Fixed WebSocket ping tasks being prematurely garbage collected -- by
:user:`bdraco`.

There was a small risk that WebSocket ping tasks would be prematurely
garbage collected because the event loop only holds a weak reference to
the task. The garbage collection risk has been fixed by holding a strong
reference to the task. Additionally, the task is now scheduled eagerly
with Python 3.12+ to increase the chance it can be completed immediately
and avoid having to hold any references to the task.

    *Related issues and pull requests on GitHub:*
    :issue:`8641`.

- Fixed incorrectly following symlinks for compressed file variants --
by :user:`steverep`.

    *Related issues and pull requests on GitHub:*
    :issue:`8652`.

## Removals and backward incompatible breaking changes

- Removed `Request.wait_for_disconnection()`, which was mistakenly added
briefly in 3.10.0 -- by :user:`Dreamsorcerer`.

    *Related issues and pull requests on GitHub:*
    :issue:`8636`.

## Contributor-facing changes

- Fixed monkey patches for `Path.stat()` and `Path.is_dir()` for Python
3.13 compatibility -- by :user:`steverep`.

    *Related issues and pull requests on GitHub:*
    :issue:`8551`.

## Miscellaneous internal changes

- Improved WebSocket performance when messages are sent or received
frequently -- by :user:`bdraco`.

The WebSocket heartbeat scheduling algorithm was improved to reduce the
`asyncio` scheduling overhead by decreasing the number of
`asyncio.TimerHandle` creations and cancellations.

    *Related issues and pull requests on GitHub:*
    :issue:`8608`.

- Minor improvements to various type annotations -- by
:user:`Dreamsorcerer`.

    *Related issues and pull requests on GitHub:*
    :issue:`8634`.

***

###
[`v3.10.1`](https://redirect.github.com/aio-libs/aiohttp/compare/v3.10.0...v3.10.1)

[Compare
Source](https://redirect.github.com/aio-libs/aiohttp/compare/v3.10.0...v3.10.1)

###
[`v3.10.0`](https://redirect.github.com/aio-libs/aiohttp/compare/v3.9.5...v3.10.0)

[Compare
Source](https://redirect.github.com/aio-libs/aiohttp/compare/v3.9.5...v3.10.0)

</details>

---

### Configuration

📅 **Schedule**: Branch creation - At any time (no schedule defined),
Automerge - At any time (no schedule defined).

🚦 **Automerge**: Enabled.

♻ **Rebasing**: Whenever PR is behind base branch, or you tick the
rebase/retry checkbox.

🔕 **Ignore**: Close this PR and you won't be reminded about this update
again.

---

- [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check
this box

---

This PR was generated by [Mend Renovate](https://mend.io/renovate/).
View the [repository job
log](https://developer.mend.io/github/GoogleCloudPlatform/generative-ai).

<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzOC44MC4wIiwidXBkYXRlZEluVmVyIjoiMzguODAuMCIsInRhcmdldEJyYW5jaCI6Im1haW4iLCJsYWJlbHMiOltdfQ==-->
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants